Perl Text::CSV_XS 從字符串中讀取 (Perl Text::CSV_XS read from string)


問題描述

Perl Text::CSV_XS 從字符串中讀取 (Perl Text::CSV_XS read from string)

How to I use the Text::CSV_XS module to read its input from a CSV string. Then only information I can find documented is reading from a file.

Would the fastest way to do it be splitting up the CSV string using the perl split function and reading each line from there or is there some built in method with Text::CSV_XS to read directly from a CSV string?

Thanks

‑‑‑‑‑

參考解法

方法 1:

The getline method of Text::CSV_XS will read from a file handle, so you can open the scalar string as a stream and pass that file handle.

This program demonstrates

use strict;
use warnings;

use Text::CSV_XS;

my $string = <<'END';
a,b,c,d
e,f,g,h
i,j,k,l
m,n,o,p
END


my $csv = Text::CSV_XS‑>new;
open my $fh, '<', \$string;

while (my $row = $csv‑>getline($fh)) {
  print join('‑', @$row), "\n";
}

output

a‑b‑c‑d
e‑f‑g‑h
i‑j‑k‑l
m‑n‑o‑p

方法 2:

Use the parse method;

#!/usr/bin/env perl
#
use strict;
use warnings;
use Data::Dumper;

use Text::CSV_XS;

my $csv = Text::CSV_XS‑>new();
if ( $csv‑>parse('Column1,Column2,Column2') ) {
    my @columns = $csv‑>fields;
    print Dumper( \@columns );
}
else {
    # Failed to parse the CSV data
}

(by AdamBorodintoreau)

參考文件

  1. Perl Text::CSV_XS read from string (CC BY‑SA 3.0/4.0)

#perl #string #CSV #file #text






相關問題

保持特定位數的簡單 Perl 數學 (simple Perl math while keeping a specific number of digits)

如何在 Windows 批處理腳本或 Perl 中將文件移動到回收站? (How can I move files to the Recycle Bin in a Windows batch script or Perl?)

從子程序返回數組 (Return array from subroutine)

我可以以與操作系統無關的方式限制 Perl 進程使用的內存嗎? (Can I Iimit the memory used by a Perl process in an OS-agnostic way?)

$# 在 perl 中接受什麼作為輸入? (what does $# accept as input in perl?)

Perl Text::CSV_XS 從字符串中讀取 (Perl Text::CSV_XS read from string)

使用 excel 2010 更新批處理文件中的變量 (use excel 2010 to update variables in batch file)

在 perl 中為哈希添加值 (Adding value to an hash in perl)

為什麼 perl 會忽略我的正則表達式中的多餘字符? (Why does perl ignore extra characters in my regex?)

boost::regex - \bb? (boost::regex - \bb?)

如果小於 X 天,如何從磁盤讀取文件,如果舊,則重新獲取 html 文件 (How to read a file from the disk if less than X days old, if older, refetch the html file)

使用 Devel-Cover 獲取覆蓋率報告 (Using Devel-Cover to get coverage reports)







留言討論